5.5
MEDIUM CVSS 3.1
CVE-2023-52881
tcp: do not accept ACK of bytes we never sent
Description

In the Linux kernel, the following vulnerability has been resolved: tcp: do not accept ACK of bytes we never sent This patch is based on a detailed report and ideas from Yepeng Pan and Christian Rossow. ACK seq validation is currently following RFC 5961 5.2 guidelines: The ACK value is considered acceptable only if it is in the range of ((SND.UNA - MAX.SND.WND) <= SEG.ACK <= SND.NXT). All incoming segments whose ACK value doesn't satisfy the above condition MUST be discarded and an ACK sent back. It needs to be noted that RFC 793 on page 72 (fifth check) says: "If the ACK is a duplicate (SEG.ACK < SND.UNA), it can be ignored. If the ACK acknowledges something not yet sent (SEG.ACK > SND.NXT) then send an ACK, drop the segment, and return". The "ignored" above implies that the processing of the incoming data segment continues, which means the ACK value is treated as acceptable. This mitigation makes the ACK check more stringent since any ACK < SND.UNA wouldn't be accepted, instead only ACKs that are in the range ((SND.UNA - MAX.SND.WND) <= SEG.ACK <= SND.NXT) get through. This can be refined for new (and possibly spoofed) flows, by not accepting ACK for bytes that were never sent. This greatly improves TCP security at a little cost. I added a Fixes: tag to make sure this patch will reach stable trees, even if the 'blamed' patch was adhering to the RFC. tp->bytes_acked was added in linux-4.2 Following packetdrill test (courtesy of Yepeng Pan) shows the issue at hand: 0 socket(..., SOCK_STREAM, IPPROTO_TCP) = 3 +0 setsockopt(3, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0 +0 bind(3, ..., ...) = 0 +0 listen(3, 1024) = 0 // ---------------- Handshake ------------------- // // when window scale is set to 14 the window size can be extended to // 65535 * (2^14) = 1073725440. Linux would accept an ACK packet // with ack number in (Server_ISN+1-1073725440. Server_ISN+1) // ,though this ack number acknowledges some data never // sent by the server. +0 < S 0:0(0) win 65535 <mss 1400,nop,wscale 14> +0 > S. 0:0(0) ack 1 <...> +0 < . 1:1(0) ack 1 win 65535 +0 accept(3, ..., ...) = 4 // For the established connection, we send an ACK packet, // the ack packet uses ack number 1 - 1073725300 + 2^32, // where 2^32 is used to wrap around. // Note: we used 1073725300 instead of 1073725440 to avoid possible // edge cases. // 1 - 1073725300 + 2^32 = 3221241997 // Oops, old kernels happily accept this packet. +0 < . 1:1001(1000) ack 3221241997 win 65535 // After the kernel fix the following will be replaced by a challenge ACK, // and prior malicious frame would be dropped. +0 > . 1:1(0) ack 1001

INFO

Published Date :

May 29, 2024, 11:16 a.m.

Last Modified :

Sept. 27, 2025, midnight

Remotely Exploit :

No

Source :

416baaa9-dc9f-4396-8d5f-8c081fb06d67
Affected Products

The following products are affected by CVE-2023-52881 vulnerability. Even if cvefeed.io is aware of the exact versions of the products that are affected, the information is not represented in the table below.

ID Vendor Product Action
1 Linux linux_kernel
CVSS Scores
The Common Vulnerability Scoring System is a standardized framework for assessing the severity of vulnerabilities in software and systems. We collect and displays CVSS scores from various sources for each CVE.
Score Version Severity Vector Exploitability Score Impact Score Source
CVSS 3.1 MEDIUM [email protected]
Solution
This vulnerability is addressed by updating the Linux kernel packages.
  • Update kernel packages to resolve the TCP ACK validation issue.
  • Reboot the system to apply the kernel updates.
CWE - Common Weakness Enumeration

While CVE identifies specific instances of vulnerabilities, CWE categorizes the common flaws or weaknesses that can lead to vulnerabilities. CVE-2023-52881 is associated with the following CWEs:

Common Attack Pattern Enumeration and Classification (CAPEC)

Common Attack Pattern Enumeration and Classification (CAPEC) stores attack patterns, which are descriptions of the common attributes and approaches employed by adversaries to exploit the CVE-2023-52881 weaknesses.

We scan GitHub repositories to detect new proof-of-concept exploits. Following list is a collection of public exploits and proof-of-concepts, which have been published on GitHub (sorted by the most recently updated).

Results are limited to the first 15 repositories due to potential performance issues.

The following list is the news that have been mention CVE-2023-52881 vulnerability anywhere in the article.

The following table lists the changes that have been made to the CVE-2023-52881 vulnerability over time.

Vulnerability history details can be useful for understanding the evolution of a vulnerability, and for identifying the most recent changes that may impact the vulnerability's severity, exploitability, or other characteristics.

  • Initial Analysis by [email protected]

    Sep. 27, 2025

    Action Type Old Value New Value
    Added CVSS V3.1 AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
    Added CWE NVD-CWE-noinfo
    Added CPE Configuration OR *cpe:2.3:o:linux:linux_kernel:6.7:rc1:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:6.7:rc2:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:6.7:rc3:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:6.7:rc4:*:*:*:*:*:* *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.16 up to (excluding) 6.1.68 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.11 up to (excluding) 5.15.143 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 3.0.58 up to (excluding) 3.1 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 3.2.37 up to (excluding) 3.3 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 3.4.25 up to (excluding) 3.5 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 3.8 up to (excluding) 4.14.333 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 4.15 up to (excluding) 4.19.302 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 4.20 up to (excluding) 5.4.264 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 5.5 up to (excluding) 5.10.204 *cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* versions from (including) 6.2 up to (excluding) 6.6.7
    Added Reference Type CVE: https://git.kernel.org/stable/c/008b807fe487e0b15a3a6c39add4eb477f73e440 Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/008b807fe487e0b15a3a6c39add4eb477f73e440 Types: Patch
    Added Reference Type CVE: https://git.kernel.org/stable/c/0d4e0afdd6658cd21dd5be61880411a2553fd1fc Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/0d4e0afdd6658cd21dd5be61880411a2553fd1fc Types: Patch
    Added Reference Type CVE: https://git.kernel.org/stable/c/2087d53a66e97a5eb5d1bf558d5bef9e5f891757 Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/2087d53a66e97a5eb5d1bf558d5bef9e5f891757 Types: Patch
    Added Reference Type CVE: https://git.kernel.org/stable/c/3d501dd326fb1c73f1b8206d4c6e1d7b15c07e27 Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/3d501dd326fb1c73f1b8206d4c6e1d7b15c07e27 Types: Patch
    Added Reference Type CVE: https://git.kernel.org/stable/c/458f07ffeccd17f99942311e09ef574ddf4a414a Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/458f07ffeccd17f99942311e09ef574ddf4a414a Types: Patch
    Added Reference Type CVE: https://git.kernel.org/stable/c/69eae75ca5255e876628ac5cee9eaab31f644b57 Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/69eae75ca5255e876628ac5cee9eaab31f644b57 Types: Patch
    Added Reference Type CVE: https://git.kernel.org/stable/c/7ffff0cc929fdfc62a74b384c4903d6496c910f0 Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/7ffff0cc929fdfc62a74b384c4903d6496c910f0 Types: Patch
    Added Reference Type CVE: https://git.kernel.org/stable/c/b17a886ed29f3b70b78ccf632dad03e0c69e3c1a Types: Patch
    Added Reference Type kernel.org: https://git.kernel.org/stable/c/b17a886ed29f3b70b78ccf632dad03e0c69e3c1a Types: Patch
  • CVE Modified by af854a3a-2127-422b-91ae-364da2661108

    Nov. 21, 2024

    Action Type Old Value New Value
    Added Reference https://git.kernel.org/stable/c/008b807fe487e0b15a3a6c39add4eb477f73e440
    Added Reference https://git.kernel.org/stable/c/0d4e0afdd6658cd21dd5be61880411a2553fd1fc
    Added Reference https://git.kernel.org/stable/c/2087d53a66e97a5eb5d1bf558d5bef9e5f891757
    Added Reference https://git.kernel.org/stable/c/3d501dd326fb1c73f1b8206d4c6e1d7b15c07e27
    Added Reference https://git.kernel.org/stable/c/458f07ffeccd17f99942311e09ef574ddf4a414a
    Added Reference https://git.kernel.org/stable/c/69eae75ca5255e876628ac5cee9eaab31f644b57
    Added Reference https://git.kernel.org/stable/c/7ffff0cc929fdfc62a74b384c4903d6496c910f0
    Added Reference https://git.kernel.org/stable/c/b17a886ed29f3b70b78ccf632dad03e0c69e3c1a
  • CVE Received by 416baaa9-dc9f-4396-8d5f-8c081fb06d67

    May. 29, 2024

    Action Type Old Value New Value
    Added Description In the Linux kernel, the following vulnerability has been resolved: tcp: do not accept ACK of bytes we never sent This patch is based on a detailed report and ideas from Yepeng Pan and Christian Rossow. ACK seq validation is currently following RFC 5961 5.2 guidelines: The ACK value is considered acceptable only if it is in the range of ((SND.UNA - MAX.SND.WND) <= SEG.ACK <= SND.NXT). All incoming segments whose ACK value doesn't satisfy the above condition MUST be discarded and an ACK sent back. It needs to be noted that RFC 793 on page 72 (fifth check) says: "If the ACK is a duplicate (SEG.ACK < SND.UNA), it can be ignored. If the ACK acknowledges something not yet sent (SEG.ACK > SND.NXT) then send an ACK, drop the segment, and return". The "ignored" above implies that the processing of the incoming data segment continues, which means the ACK value is treated as acceptable. This mitigation makes the ACK check more stringent since any ACK < SND.UNA wouldn't be accepted, instead only ACKs that are in the range ((SND.UNA - MAX.SND.WND) <= SEG.ACK <= SND.NXT) get through. This can be refined for new (and possibly spoofed) flows, by not accepting ACK for bytes that were never sent. This greatly improves TCP security at a little cost. I added a Fixes: tag to make sure this patch will reach stable trees, even if the 'blamed' patch was adhering to the RFC. tp->bytes_acked was added in linux-4.2 Following packetdrill test (courtesy of Yepeng Pan) shows the issue at hand: 0 socket(..., SOCK_STREAM, IPPROTO_TCP) = 3 +0 setsockopt(3, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0 +0 bind(3, ..., ...) = 0 +0 listen(3, 1024) = 0 // ---------------- Handshake ------------------- // // when window scale is set to 14 the window size can be extended to // 65535 * (2^14) = 1073725440. Linux would accept an ACK packet // with ack number in (Server_ISN+1-1073725440. Server_ISN+1) // ,though this ack number acknowledges some data never // sent by the server. +0 < S 0:0(0) win 65535 <mss 1400,nop,wscale 14> +0 > S. 0:0(0) ack 1 <...> +0 < . 1:1(0) ack 1 win 65535 +0 accept(3, ..., ...) = 4 // For the established connection, we send an ACK packet, // the ack packet uses ack number 1 - 1073725300 + 2^32, // where 2^32 is used to wrap around. // Note: we used 1073725300 instead of 1073725440 to avoid possible // edge cases. // 1 - 1073725300 + 2^32 = 3221241997 // Oops, old kernels happily accept this packet. +0 < . 1:1001(1000) ack 3221241997 win 65535 // After the kernel fix the following will be replaced by a challenge ACK, // and prior malicious frame would be dropped. +0 > . 1:1(0) ack 1001
    Added Reference kernel.org https://git.kernel.org/stable/c/69eae75ca5255e876628ac5cee9eaab31f644b57 [No types assigned]
    Added Reference kernel.org https://git.kernel.org/stable/c/458f07ffeccd17f99942311e09ef574ddf4a414a [No types assigned]
    Added Reference kernel.org https://git.kernel.org/stable/c/7ffff0cc929fdfc62a74b384c4903d6496c910f0 [No types assigned]
    Added Reference kernel.org https://git.kernel.org/stable/c/b17a886ed29f3b70b78ccf632dad03e0c69e3c1a [No types assigned]
    Added Reference kernel.org https://git.kernel.org/stable/c/0d4e0afdd6658cd21dd5be61880411a2553fd1fc [No types assigned]
    Added Reference kernel.org https://git.kernel.org/stable/c/008b807fe487e0b15a3a6c39add4eb477f73e440 [No types assigned]
    Added Reference kernel.org https://git.kernel.org/stable/c/2087d53a66e97a5eb5d1bf558d5bef9e5f891757 [No types assigned]
    Added Reference kernel.org https://git.kernel.org/stable/c/3d501dd326fb1c73f1b8206d4c6e1d7b15c07e27 [No types assigned]
EPSS is a daily estimate of the probability of exploitation activity being observed over the next 30 days. Following chart shows the EPSS score history of the vulnerability.
Vulnerability Scoring Details
Base CVSS Score: 5.5
Attack Vector
Attack Complexity
Privileges Required
User Interaction
Scope
Confidentiality Impact
Integrity Impact
Availability Impact